<!DOCTYPE html>

<meta charset="utf-8" />
<meta name="viewport" />
<title>test</title>


<style>
  div {
    border :1px solid red;
    width: 100px; height: 100px;
  }
</style>

<div data-is-delay="false"></div>

<script type="text/javascript;version=1.8">
  "use strict";
  let div = document.querySelector("div");
  let initX, initY;
  let previousEvent = "", touchendTime = 0;
  let updatePreviousEvent = function (e) {
    previousEvent = e.type;
  };

  div.style.transform = "none";
  div.style.backgroundColor = "";

  div.addEventListener("touchstart", function (evt) {
    let touch = evt.changedTouches[0];
    initX = touch.pageX;
    initY = touch.pageY;
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("touchmove", function (evt) {
    let touch = evt.changedTouches[0];
    let deltaX = touch.pageX - initX;
    let deltaY = touch.pageY - initY;
    div.style.transform = "translate(" + deltaX + "px, " + deltaY + "px)";
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("touchend", function (evt) {
    if (!evt.touches.length) {
      div.style.transform = "none";
    }
    touchendTime = performance.now();
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("mouseenter", function (evt) {
    div.style.backgroundColor = "red";
    updatePreviousEvent(evt);
  }, true);
  div.addEventListener("mouseover", function(evt) {
    div.style.backgroundColor = "red";
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("mouseout", function (evt) {
    div.style.backgroundColor = "blue";
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("mouseleave", function (evt) {
    div.style.backgroundColor = "blue";
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("mousedown", function (evt) {
    if (previousEvent === "touchend" && touchendTime !== 0) {
      let now = performance.now();
      div.dataset.isDelay = ((now - touchendTime) >= 300);
    } else {
      div.dataset.isDelay = false;
    }
    updatePreviousEvent(evt);
  }, true);

  div.addEventListener("mousemove", updatePreviousEvent, true);

  div.addEventListener("mouseup", updatePreviousEvent, true);

  div.addEventListener("click", updatePreviousEvent, true);
</script>
